/*
 * Copyright 2016 Google Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.google.j2cl.junit.integration.async.data;

import com.google.j2cl.junit.async.AsyncTestRunner;
import com.google.j2cl.junit.integration.testing.async.Thenable;
import com.google.j2cl.junit.integration.testing.async.Timer;
import com.google.j2cl.junit.integration.testing.testlogger.TestCaseLogger;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;

@RunWith(AsyncTestRunner.class)
public class TestAfterWithFailingAsyncTest {

  @Before
  public void before() {
    TestCaseLogger.log("Before method ran!");
  }

  @After
  public void after() {
    TestCaseLogger.log("After method ran!");
  }

  @Test(timeout = 200L)
  public Thenable testAfterWithFailingAsyncTest() {
    TestCaseLogger.log("test method ran!");
    return (onFulfilled, onRejected) -> {
      Timer.schedule(
          () -> {
            TestCaseLogger.log("promise rejected!");
            onRejected.execute(new Exception("Should see this message"));
          },
          0);
    };

  }
}
